$(function () {
  var layer = layui.layer;
  var form = layui.form;
  load();
  // 初始化富文本编辑器
  initEditor();
  // 定义加载文章分类的函数
  function load() {
    $.ajax({
      type: "GET",
      url: "/my/article/cates",
      success: function (res) {
        if (res.status !== 0) return layer.msg(res.message);
        // 调用模板引擎
        var htmlStr = template("pub_cate", res);
        $("[name=cate_id]").html(htmlStr);
        // 一定要记得调用form.render方法
        form.render();
      },
    });
  }
  // 1. 初始化图片裁剪器
  var $image = $("#image");

  // 2. 裁剪选项
  var options = {
    aspectRatio: 400 / 280,
    preview: ".img-preview",
  };

  // 3. 初始化裁剪区域
  $image.cropper(options);
  //   为选择封面添加点击事件
  $("#pub-btn").on("click", function () {
    $("#pub-file").click();
  });
  //监听文件上传的change事件
  $("#pub-file").on("change", function (e) {
    //  获取文件选择框的列表数组
    var files = e.target.files;
    if (files.length < 0) return layer.msg("请选择文件");
    // 根据选择的文件，创建一个对应的 URL 地址：
    var newImgURL = URL.createObjectURL(files[0]);
    // 为裁剪区重新设置图片
    $image
      .cropper("destroy") // 销毁旧的裁剪区域
      .attr("src", newImgURL) // 重新设置图片路径
      .cropper(options); // 重新初始化裁剪区域
  });
  //   定义文章的状态
  var state = "已发布";
  //   为存入草稿绑定点击事件
  $("#draft1").on("click", function () {
    state = "草稿";
  });
  //   为表单添加submit事件
  $("#pub_form").on("submit", function (e) {
    e.preventDefault();
    // 基于form表单，快速创建一个formData对象
    var fd = new FormData($(this)[0]);
    fd.append("state", state);
    // 将裁剪后的图片，输出为文件
    $image
      .cropper("getCroppedCanvas", {
        // 创建一个 Canvas 画布
        width: 400,
        height: 280,
      })
      .toBlob(function (blob) {
        // 将 Canvas 画布上的内容，转化为文件对象
        // 追加到fd中
        fd.append("cover_img", blob);
        // 发起ajax请求;
        releasewen(fd);
      });
  });
  //   定义一个发布文章的方法
  function releasewen(fd) {
    $.ajax({
      type: "POST",
      url: "/my/article/add",
      data: fd,
      //   如果向服务器提交的死formdata对象时
      // 必须添加以下二个属性
      contentType: false,
      processData: false,
      success: function (res) {
        if (res.status !== 0) return layer.msg(res.message);
        layer.msg(res.message);
        $("#pub_form")[0].reset();
        // 成功后跳转到文章页面中
        window.parent.$("#wenz")[0].click();
      },
    });
  }
});
